$(function () {
    var layer = layui.layer;
    var form = layui.form;

    // 初始化富文本编辑器
    initEditor();

    // 1. 初始化图片裁剪器
    var $image = $('#image');

    // 2. 裁剪选项
    var options = {
        aspectRatio: 400 / 280,
        preview: '.img-preview'
    }

    // 3. 初始化裁剪区域
    $image.cropper(options);

    initCateList();
    // 分类获取并渲染
    function initCateList() {
        $.ajax({
            method: 'GET',
            url: '/my/article/cates',
            success: function (res) {
                if (res.status !== 0) {
                    return layer.msg('获取分类失败');
                }
                var strHtml = template('cate-list', res);
                $('[name = cate_id]').html(strHtml);
                form.render();
            }
        })
    }

    // 选择封面图片
    $('#btnChangeImg').on('click', function () {
        $('#file').click();
    })

    // 选择文件后的操作
    $('#file').on('change', function (e) {
        var files = e.target.files;
        if (files.length === 0) {
            return layer.msg('请选择要上传的图片');
        }
        // 将上传的文件生成一个新的url
        var newImgURL = URL.createObjectURL(files[0]);
        $image
            .cropper('destroy')      // 销毁旧的裁剪区域
            .attr('src', newImgURL)  // 重新设置图片路径
            .cropper(options)        // 重新初始化裁剪区域
    });

    var art_state = '已发布';

    // 存为草稿
    $('#btnSave').on('click', function () {
        art_state = '草稿';

    })

    // 提交发布
    $('#formAdd').on('submit', function (e) {
        e.preventDefault();
        var fd = new FormData($(this)[0]);
        fd.append('state', art_state);
        $image
            .cropper('getCroppedCanvas', {
                // 创建一个 Canvas 画布
                width: 400,
                height: 280
            })
            .toBlob(function (blob) {
                // 将 Canvas 画布上的内容，转化为文件对象
                // 得到文件对象后，进行后续的操作
                // 5. 将文件对象，存储到 fd 中
                fd.append('cover_img', blob)
                
                // 6. 发起 ajax 数据请求
                publishArticle(fd);
            })
    });

    // 发布文章的ajax
    function publishArticle(fd) {
        $.ajax({
            method: 'POST',
            url:'/my/article/add',
            data: fd,
            contentType: false,
            processData: false,
            success: function(res) {
                if(res.status !== 0) {
                    return layer.msg('文章发布失败');
                }
                layer.msg('文章发布成功');
                location.href = "/article/art_list.html"
            }
        })
    }

    







})